:root,
:host {
  --van-tag-padding: 0 var(--van-padding-base);
  --van-tag-text-color: var(--van-white);
  --van-tag-font-size: var(--van-font-size-sm);
  --van-tag-radius: 2px;
  --van-tag-line-height: 16px;
  --van-tag-medium-padding: 2px 6px;
  --van-tag-large-padding: var(--van-padding-base) var(--van-padding-xs);
  --van-tag-large-radius: var(--van-radius-md);
  --van-tag-large-font-size: var(--van-font-size-md);
  --van-tag-round-radius: var(--van-radius-max);
  --van-tag-danger-color: var(--van-danger-color);
  --van-tag-primary-color: var(--van-primary-color);
  --van-tag-success-color: var(--van-success-color);
  --van-tag-warning-color: var(--van-warning-color);
  --van-tag-default-color: var(--van-gray-6);
  --van-tag-plain-background: var(--van-background-2);
}

.van-tag {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: var(--van-tag-padding);
  color: var(--van-tag-text-color);
  font-size: var(--van-tag-font-size);
  line-height: var(--van-tag-line-height);
  border-radius: var(--van-tag-radius);

  &--default {
    background: var(--van-tag-default-color);

    &.van-tag--plain {
      color: var(--van-tag-default-color);
    }
  }

  &--danger {
    background: var(--van-tag-danger-color);

    &.van-tag--plain {
      color: var(--van-tag-danger-color);
    }
  }

  &--primary {
    background: var(--van-tag-primary-color);

    &.van-tag--plain {
      color: var(--van-tag-primary-color);
    }
  }

  &--success {
    background: var(--van-tag-success-color);

    &.van-tag--plain {
      color: var(--van-tag-success-color);
    }
  }

  &--warning {
    background: var(--van-tag-warning-color);

    &.van-tag--plain {
      color: var(--van-tag-warning-color);
    }
  }

  &--plain {
    background: var(--van-tag-plain-background);
    border-color: currentColor;

    &::before {
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      border: 1px solid;
      border-color: inherit;
      border-radius: inherit;
      content: '';
      pointer-events: none;
    }
  }

  &--medium {
    padding: var(--van-tag-medium-padding);
  }

  &--large {
    padding: var(--van-tag-large-padding);
    font-size: var(--van-tag-large-font-size);
    border-radius: var(--van-tag-large-radius);
  }

  &--mark {
    border-radius: 0 var(--van-tag-round-radius) var(--van-tag-round-radius) 0;

    &::after {
      display: block;
      width: 2px;
      content: '';
    }
  }

  &--round {
    border-radius: var(--van-tag-round-radius);
  }

  &__close {
    margin-left: 2px;
  }
}
